if-statement - If - Else 条件
全部标签 是否可以在您的ActiveRecord模型中使用委托(delegate)并在其上使用类似:if的条件?classUser:master,:if=>:has_master?belongs_to:master,:class_name=>"User"defhas_master?master.present?endend 最佳答案 不,你不能,但你可以传递:allow_nil=>true选项以在master为nil时返回nil。classUser:master,:allow_nil=>true#...enduser.master=nilus
我正在尝试在Rails应用程序中进行有条件的before_save,但它似乎不起作用。before_savemethod_call_to_runifself.related_model.some_method_that_returns_t_or_f?如果“some_method_that_returns_t_or_f”返回true,我希望它在保存对象之前运行该方法,否则我只希望它忽略before_save。 最佳答案 你可以使用:ifbefore_savedo_something,:if=>Proc.new{|model|model
我想关闭特定的Rubocop警告:AssignmentBranchConditionsizeforplot_defaultsistoohigh.[21.05/15]在注释行的代码中执行此操作的适当语法是什么,例如:#rubocop:disable 最佳答案 我相信这是Metrics/AbcSizecop.的消息#rubocop:disableMetrics/AbcSize 关于ruby-如何消除分配分支条件下的Rubocop警告?,我们在StackOverflow上找到一个类似的问题:
有很多地方需要补充ifthis_flagreturnend可以用ruby在一行中完成吗? 最佳答案 istherearubyone-line“returnifx”?是的:returnvalueifcondition我喜欢Ruby:-) 关于ruby-有ruby单行"returnifx"吗?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/5436034/
简而言之,为什么以下三行的影响不同?if@controller.controller_name=="projects"||@controller.controller_name=="parts"if@controller.controller_name==("projects"||"parts")if@controller.controller_name=="projects"||"parts"第一个给了我想要的结果,但由于实际上有更多的选项而不仅仅是项目和部分,因此使用该表单会创建一个冗长的语句。其他两个更紧凑,但不要给我相同的结果。 最佳答案
我与同事争论在if..elseblock中分配变量的最佳方法。他的原始代码是:@products=ifparams[:category]Category.find(params[:category]).productselseProduct.allend我是这样重写的:ifparams[:category]@products=Category.find(params[:category]).productselse@products=Product.allend这也可以使用三元运算符(?:)用单行代码重写,但我们假设产品分配的长度超过100个字符并且不能放在一行中。这两个你更清楚哪个?
我知道在Ruby中有一个简写的单行if/else语句:a?b:c是否只有一个if语句?而不是这样写:ifa#dosomethingend有这个的简写版本吗? 最佳答案 您可以使用后置条件(不要介意名称,它会在代码之前被评估。而do_something只会被如果条件评估为真值(即不是nil或false)则执行。do_somethingifa 关于ruby-RubyonRails中是否有简写if(没有else)语句?,我们在StackOverflow上找到一个类似的问题:
我正在使用RubyonRails3.0.10,我想以有条件的方式构建哈希键\值对。也就是说,如果条件匹配,我想添加一个键及其相关值:hash={:key1=>value1,:key2=>value2,#Thiskey2\value2pairshouldbeaddedonly'ifcondition'is'true':key3=>value3,...}我怎样才能做到这一点并保持代码的“良好”可读性?我是否“被迫”使用merge方法? 最佳答案 我更喜欢tap,因为我认为它提供了比这里描述的解决方案更清晰的解决方案,因为它不需要对元素进
在Rails中,我经常遇到这样的情况,在View中我会做类似的事情123somethingelse看起来有点乱。这是处理View的可接受方式吗? 最佳答案 除非您能想出一种方法将其重写为辅助方法,否则您基本上只能坚持使用它,看起来有点丑陋。ERB就是这样,因为它旨在成为将Ruby注入(inject)其他纯文本模板的最小方式,而不是必须流线型或优雅的东西。好消息是语法高亮编辑器通常会让你的ERBblock在视觉上与您的HTML不同,因此可以显着提高可读性。这也是为什么其他表示形式如HAML的原因已经创建了语法不那么困惑的地方:-ifs
在elsif上使用elseif是否安全?使用elsif是否更好,因为它遵循Ruby的类型惯例?或者这是一种偏好?这是摘自一本书的一段代码。我添加了额外的end关键字并将elsif关键字替换为elseif。defdescribe(inhabitant)ifinhabitant=="sophie"puts'gender:female'puts'height:145'elseifinhabitant=="paul"puts'gender:male'puts'height:145'elseifinhabitant=="dawn"puts'gender:female'puts'height:17